<!--页面-->
<template>
  <el-container>
    <!--左侧-->
    <el-aside width="200px">
      <img src="../assets/loginBox.svg">
      <p class="imgTitle">
        欢迎使用晨希云客系统
      </p>
    </el-aside>

    <!--右侧-->
    <el-main>

      <div class="loginTile">欢迎登录</div>

      <el-form ref="loginRefForm" :model="user" label-width="120px" :rules="loginRules">
        <el-form-item label="账号" prop="loginAct">
          <el-input v-model="user.loginAct"/>
        </el-form-item>

        <el-form-item label="密码" prop="loginPwd">
          <el-input type="password" v-model="user.loginPwd"/>
        </el-form-item>

        <el-form-item>
          <el-button type="primary" @click="login">登 录</el-button>
        </el-form-item>

        <el-form-item>
          <el-checkbox label="记住账号与密码" v-model="user.rememberMe"/>
        </el-form-item>

      </el-form>

    </el-main>
  </el-container>
</template>

<!--名字-->
<script>
import {doGet, doPost} from "../http/httpRequest.js";
import {getTokenName, messageTip, removeToken} from "../util/util.js";
import {defineComponent} from "vue";

export default defineComponent({
  //组件名字
  name: "LoginView",
  //定义页面使用到的变量,定义时的初始值都是空的
  data() {
    return {
      //对象变量定义，是{}
      user: {},
      //字符串变量定义，是''
      name: '',
      //数字定义，是0
      age: 0,
      //数组定义，是[]
      arr: [],
      //list集合对象（对象数组），是[{}]
      userList: [{}],
      //定义登录表单验证规则
      loginRules: {
        //定义账号验证规则，规则可以有多个，所以是数组
        loginAct: [
          {required: true, message: '请输入登录账号', trigger: 'blur'}
        ],
        //定义密码的验证规则，规则可以有多个，所以是数组
        loginPwd: [
          {required: true, message: '请输入登录密码', trigger: 'blur'},
          {min: 6, max: 16, message: '登录密码长度为6-16位', trigger: 'blur'}
        ]
      }
    }
  },

  //定义到页面使用到的变量，定义时初始值都是给个空的
  mounted() {
    this.freeLogin();
  },

  //页面上需要使用功能的js函数，都要在methods属性中定义
  methods: {
    //登录函数
    login() {
      //提交前验证输入框的合法性
      this.$refs.loginRefForm.validate((isValid) => {
        //isValid是验证后的结果，如果是true表示验证通过，否则未通过
        if (isValid) {
          //验证通过，可以提交
          let formData = new FormData();
          formData.append("loginAct", this.user.loginAct)
          formData.append("loginPwd", this.user.loginPwd)
          formData.append("rememberMe", this.user.rememberMe)

          doPost("/api/login", formData).then((resp) => {
            console.log(resp)
            if(resp.data.code === 200){
              //登陆成功，提示一下
              messageTip("登录成功","success");

              //删除一下历史localStorage和sessionStorage中存储的token
              removeToken();

              //前端存储jwt
              if (this.user.rememberMe === true) {
                window.localStorage.setItem(getTokenName(),resp.data.data);
              }else {
                window.sessionStorage.setItem(getTokenName(),resp.data.data);
              }

              //跳转到系统的主页面
              window.location.href = "/dashboard";
            }else{
              //登录失败
              messageTip("登录失败","error")
            }
          });
        }
      })
    },

    //免登录函数
    freeLogin(){
      let token = window.localStorage.getItem(getTokenName());
      if (token){ //表示token有值，token不是空，token存在
        doGet("/api/login/free",{}).then(resp =>{
          if (resp.data.code === 200){
            //token验证通过了，那么可以免登录
            window.location.href = "/dashboard";
          }
        })
      }
    }
  }
})
</script>

<!--样式-->
<style scoped>
.el-aside {
  background-color: #D3DCE6;
  width: 40%;
  text-align: center;
}

.el-main {
  height: calc(100vh);
}

img {
  height: 413px;
}

.imgTitle {
  color: #1a1a1a;
  font-size: 28px;
}

.el-form {
  width: 60%;
  margin: auto;
}

.loginTile {
  text-align: center;
  margin-top: 100px;
  margin-bottom: 25px;
  font-weight: bold;
}

.el-button {
  width: 100%;
}
</style>